From 2ff898626c5c0abc6b8195224067b992403e313b Mon Sep 17 00:00:00 2001 From: Armand Philippot Date: Sat, 18 Dec 2021 16:07:44 +0100 Subject: chore: add subject view --- src/pages/sujet/[slug].tsx | 96 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 96 insertions(+) create mode 100644 src/pages/sujet/[slug].tsx (limited to 'src/pages/sujet/[slug].tsx') diff --git a/src/pages/sujet/[slug].tsx b/src/pages/sujet/[slug].tsx new file mode 100644 index 0000000..a6acf2b --- /dev/null +++ b/src/pages/sujet/[slug].tsx @@ -0,0 +1,96 @@ +import Layout from '@components/Layouts/Layout'; +import PostPreview from '@components/PostPreview/PostPreview'; +import { t } from '@lingui/macro'; +import { + fetchAllSubjectsSlug, + getSubjectBySlug, +} from '@services/graphql/taxonomies'; +import { NextPageWithLayout } from '@ts/types/app'; +import { SubjectProps } from '@ts/types/taxonomies'; +import { loadTranslation } from '@utils/helpers/i18n'; +import { GetStaticPaths, GetStaticProps, GetStaticPropsContext } from 'next'; +import Image from 'next/image'; +import { ParsedUrlQuery } from 'querystring'; +import { ReactElement } from 'react'; +import styles from '@styles/pages/Subject.module.scss'; + +const Subject: NextPageWithLayout = ({ subject }) => { + const getPostsList = () => { + return subject.posts.reverse().map((post) => ( +
  • + +
  • + )); + }; + + return ( +
    +
    +

    + {subject.featuredImage && ( + + {subject.featuredImage.altText} + + )} + {subject.title} +

    + {subject.officialWebsite && ( +
    +
    {t`Official website:`}
    +
    {subject.officialWebsite}
    +
    + )} +
    +
    +
    + {subject.posts.length > 0 && ( +
    +

    {t`All posts in ${subject.title}`}

    +
      {getPostsList()}
    +
    + )} +
    + ); +}; + +Subject.getLayout = function getLayout(page: ReactElement) { + return {page}; +}; + +interface PostParams extends ParsedUrlQuery { + slug: string; +} + +export const getStaticProps: GetStaticProps = async ( + context: GetStaticPropsContext +) => { + console.log(context); + const translation = await loadTranslation( + context.locale!, + process.env.NODE_ENV === 'production' + ); + const { slug } = context.params as PostParams; + const subject = await getSubjectBySlug(slug); + + return { + props: { + subject, + translation, + }, + }; +}; + +export const getStaticPaths: GetStaticPaths = async () => { + const allSlugs = await fetchAllSubjectsSlug(); + + return { + paths: allSlugs.map((post) => `/sujet/${post.slug}`), + fallback: true, + }; +}; + +export default Subject; -- cgit v1.2.3